<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"
>
<head>
    <meta charset="UTF-8">
    <title>公告管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" href="/resources/favicon.ico">
    <link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="/resources/css/public.css" media="all" />
</head>
<body class="childrenBody">
<!--查询条件开始-->
<fieldset class="layui-elem-field layui-field-title" style="margin-top: 30px;">
    <legend>查询条件</legend>
</fieldset>
<blockquote class="layui-elem-quote">
    <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">公告标题</label>
                <div class="layui-input-inline">
                    <input type="text" name="title"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">发布人</label>
                <div class="layui-input-inline">
                    <input type="text" name="opername"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">开始时间</label>
                <div class="layui-input-inline">
                    <input type="tel" name="startTime" readonly="readonly" id="startTime"  placeholder="yyyy-MM-dd HH:mm:ss"  autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">结束时间</label>
                <div class="layui-input-inline">
                    <input type="tel" name="endTime" readonly="readonly" id="endTime"  placeholder="yyyy-MM-dd HH:mm:ss"  autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center">
                <button type="button" class="layui-btn layui-btn-normal" shiro:hasPermission="notice:view" lay-submit="" lay-filter="doSearch"><span class="layui-icon layui-icon-search"></span>查询</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh"></span>重置</button>
            </div>
        </div>
    </form>
</blockquote>
<!--查询条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="noticeTable" lay-filter="noticeTable"></table>

    <div id="noticeToolBar" style="display: none">
        <button type="button" lay-event="add" shiro:hasPermission="notice:create" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-add-1"></span>添加公告</button>
        <button type="button" lay-event="batchDelete" shiro:hasPermission="notice:batchdelete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>批量删除</button>
    </div>
    <div id="noticeRowBar" style="display: none">
        <button type="button" lay-event="update" shiro:hasPermission="notice:update" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-edit"></span>更新</button>
        <button type="button" lay-event="deleteNotice" shiro:hasPermission="notice:delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
        <button type="button" lay-event="show" shiro:hasPermission="notice:viewnotice" class="layui-btn layui-btn-sm "><span class="layui-icon layui-icon-about"></span>查看</button>
    </div>
</div>
<!--数据表格结束-->

<!--添加和修改的弹出层开始-->
<div style="display: none; padding: 5px" id="addOrUpdateDiv">
    <form action="" method="post" class="layui-form layui-form-pane" id="dataForm" lay-filter="dataForm">
        <div class="layui-form-item">
            <label class="layui-form-label">公告标题</label>
            <div class="layui-input-block">
                <input type="hidden" name="id">
                <input type="text" name="title" autocomplete="off" placeholder="请输入标题" class="layui-input">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">公告内容</label>
            <div class="layui-input-block">
                <textarea class="layui-textarea " name="content" id="content"></textarea>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center">
                <button type="button" class="layui-btn layui-btn-normal" id="doSubmit"><span class="layui-icon layui-icon-release"></span>提交</button>
                <button type="reset" class="layui-btn layui-btn-warm"><span class="layui-icon layui-icon-refresh"></span>重置</button>
            </div>
        </div>
    </form>
</div>
<!--添加和修改的弹出层结束-->

<!--查看弹出层的开始-->
<div style="display: none;padding: 5px" id="showNoticeDiv">
    <h2 id="show_title" align="center"></h2>
    <div style="text-align: right">
        发布人：<span id="show_opername"></span>
        发布时间：<span id="show_createtime"></span>
    </div>
    <hr>
    <div id="show_content" style="text-align: center;color: #bd6a08;"></div>
</div>
<!--查看弹出层的结束-->

<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
    layui.use(['jquery','form','table','layer','laydate','layedit'],function (){
       var $=layui.jquery;
       var form=layui.form;
       var table=layui.table;
       var layer=layui.layer;
       var laydate=layui.laydate;
       var layedit=layui.layedit;
       //初始化时间选择器
        laydate.render({
            elem: '#startTime',
            type: 'datetime'
        });
        laydate.render({
            elem: '#endTime',
            type: 'datetime'
        });
        //初始化富文本
        var editIndex=layedit.build('content');

        //加载表格数据
        var tableIns=table.render({
            elem: '#noticeTable'
            ,url:'/sys/sys-notice/loadAllNotice'
            ,toolbar: '#noticeToolBar'
            ,height: 'full-220'
            ,title: '公告数据表'
            ,page: true
            ,cols: [ [
                {type:'checkbox',fixed:'left'}
                ,{field:'id',title: 'ID', fixed:'left' ,align:'center'}
                ,{field:'title',title: '公告标题',align:'center'}
                ,{field:'opername', title: '发布人',align:'center'}
                ,{field:'createtime',title: '发布时间',align:'center'}
                ,{fixed:'right',  title: '操作',toolbar: '#noticeRowBar',align:'center'}
            ] ]

        });

        //模糊查询
        form.on("submit(doSearch)",function (data){
           tableIns.reload({
               where:data.field, //设定异步数据接口的额外参数
               page:{
                   curr:1  //重新从第 1 页开始
               }
           })
        });

        //监听工具条事件
        table.on("toolbar(noticeTable)",function (obj){
           switch (obj.event) {
                case 'batchDelete':
                    batchDelete();
                    break;
                case 'add':
                   openAddLayer();
                   break;
           }
        });
        
        //打开添加弹出层
        var mainIndex;
        var url;
        function openAddLayer() {
            mainIndex=layer.open({
                type: 1,
                content:$("#addOrUpdateDiv"),
                area:['800px','600px'],
                title: '发布公告',
                success:function (){
                    $('#dataForm')[0].reset();
                    layedit.setContent(editIndex,"");
                    url="/sys/sys-notice/addNotice"
                }
            })

        }

        //添加和修改的提交
        $("#doSubmit").click(function () {
            //同步富文本和textarea里面的内容
            layedit.sync(editIndex);
            var data=$("#dataForm").serialize();
            $.post(url,data,function (res) {
                if (res.code==200){
                    tableIns.reload();
                }
                layer.msg(res.msg);
                layer.close(mainIndex);
            })
            return false;
        })

        //监听行工具条事件
        table.on("tool(noticeTable)",function (obj){
            var data=obj.data;//获得当前行数据
            switch (obj.event) {
                case 'deleteNotice':
                    deleteInfo(data)
                    break;
                case 'update':
                    updateInfo(data)
                    break;
                case 'show':
                    showInfo(data)
                    break;
            }
        });

        //查看弹出层
        function showInfo(data) {
            mainIndex=layer.open({
                type: 1,
                content:$("#showNoticeDiv"),
                area:['800px','600px'],
                title: '查看公告',
                success:function (){
                    $("#show_title").html(data.title);
                    $("#show_opername").html(data.opername);
                    $("#show_createtime").html(data.createtime);
                    $("#show_content").html(data.content);
                }
            })
        }

        //打开修改弹出层
        function updateInfo(data) {
            mainIndex=layer.open({
                type: 1,
                content:$("#addOrUpdateDiv"),
                area:['800px','600px'],
                title: '修改公告',
                success:function (){
                    $('#dataForm')[0].reset();
                    //装载数据内容
                    form.val("dataForm",data)
                    layedit.setContent(editIndex,data.content);
                    url="/sys/sys-notice/updateNotice"
                }
            })
        }

        //删除
        function deleteInfo(data) {
            layer.confirm('你确定要删除【'+data.title+'】这条公告?', {icon: 3, title:'提示'}, function(index){
                //do something
                $.post("/sys/sys-notice/deleteNotice", {id:data.id},function (res){
                    if (res.code==200){
                        tableIns.reload();
                    }
                    layer.msg(res.msg);
                })
                layer.close(index);
            });
        }

        //批量删除
        function batchDelete() {
            //获取选中行
            var checkStatus = table.checkStatus('noticeTable');
            var data=checkStatus.data;//获取选中行数据
            var dataLength=checkStatus.data.length;
            var ids="";
            if (dataLength>0){
                layer.confirm('你确定要删除这些数据?', {icon: 3, title:'提示'}, function(index){
                    //do something
                    $.each(data,function (index,item){
                        if (index==0){
                            ids+="ids="+item.id;
                        }else {
                            ids+="&ids="+item.id;
                        }
                    })
                    $.post("/sys/sys-notice/batchDeleteNotice",ids,function (res){
                        if (res.code==200){
                            tableIns.reload();
                        }
                        layer.msg(res.msg);
                    })
                    layer.close(index);
                });

            }else {
                layer.msg("请选择操作行")
            }

        }
    });
</script>
</body>
</html>